JAVA实现拓扑排序

本文详细介绍了如何使用JAVA实现拓扑排序,通过邻接表而非邻接矩阵来节省内存。拓扑排序是对有向无环图进行排序,通过队列处理入度为0的节点,不断出队、更新节点入度,直至队列为空。文章提供了具体的代码示例,包括Vertex和Edge类的设计,以及输入顶点和边的处理过程。
摘要由CSDN通过智能技术生成

折腾了很久才实现的拓扑排序,把代码和思路整理一下:


拓扑排序是用来对有向无环图进行排序的,和图的广度优先遍历类似,主要是利用队列把节点的入度为0(就是没有指向该节点的节点,只有从节点发出的)的元素入队,然后

1:将队首元素出队输出并寻找该元素的所有相邻元素的节点,

2:对这些节点的入度-1,并检查是否有入度减为0的,如有,则入队。

重复上述操作直到队列为空为止。


容易出问题的地方是图的建立,邻接矩阵的建立比较浪费内存,这里我是使用邻接表来建立的。这里采用两个类Vertex和Edge表示节点和边,每个Vertex的成员有一个String元素表示该节点的内容,一个Edge对象表示以该节点为起点的边,该边初始为null。每个Edge的成员有一个String元素表示该边指向的节点内容,一个Edge代表以该String元素为起点的另一条边,也就是利用链表将一个起点发出的边连接起来。

下面给出代码

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;

public class TopSort {

	Graph g ;
	
		public static void main(String[] args)
		{
			Graph g = new Graph();
			TopSort ts = new TopSor
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值